| _ВоааВиппег: ускоряем 
>НР без фреймворка _ 


Воронина Натале Я 9 ОР. 


| ИА 
| | 
| 
| 
| | ] 
| | 
р 
| | 
| | 
| 
| 
| | | 
И, | 
, 
и Ут 
| | р ] ' 
] ] 
у | 


и | 
/ ] У ы | 
у, й й 
/ | 

| 


и. рРивыа. ИИС 


Проблемы 


е 


2. 


Увеличение количества 
потребителей 


Медленная скорость 
обработки запросов 


Желание команды 
писать на Со|апз 


Варианты 


т 


2. 


Снизить количество 
запросов 


Оптимизировать код, 
оптимизировать 
запросы в базу, 
добавить кэширование 


Смириться с потерей 
части команды 


к Кизза 
2022 


- КоааКиппег — это высокопроизводительный сервер 
приложений РНР, балансировщик нагрузки и 
диспетчер процессов, написанный на Фо|апв. 


, 


3 р РН Кизза 


РНР-ЕРМ, РНР-РМ, Метпх-Цпк, Кеас*-РНР и КоааКиппег 


КоачКиппег $ опе о{ {Пе Тазфез* \ммауз {о гип уоцг РНР арр!сачцоп 


О 1000 2000 5000 


Кезропзе Пте, тэ 


кс Кизза 
2022 


Метсасйе/ 
Е аз сеагсй 


РНР Кизза 
2022 


$егуег 


Коа9Виппег 


СИскНоиц$е 


Вед!5/ 
Метсасве/ 


Е\азИсзеагсй 


Плюсы и минусы использования 


Плюсы Минусы 
ЧУ Ускорение времени ответа Ч Необходимость адаптации 
О Возможность построения в 
гибридных РНР-Со- ЧУ Возможны утечки памяти 
приложении О Сложность отладки 
- Возможность О Высокие риски при 


риОиесикы ВЕНЕРЫ Вано Нов 
о 


ЧУ Увеличение КР5, которое 
держит приложение 


7 РНР Низза 
2022 


А что, если у меня есть фреймворк? 


Тогда вам повезло, скорее всего, всю работу за вас кто-то уже 
сделал. Готовые «мосты» для перехода есть под: 


СакерРнНР 
[ ага\е! + 
Бит ® ци 


риа! Егате\могк 
я утпто пу Егате\м/огк уттопу 6 


эуптех Егате\м/огк 
Обачику Егате\могк 
Гепа Ехргеззме [агаме! 
Ун2 апа УН5 

РГа|[соп5 апа Рпасоп4 
Ме?72!0 

СвиббурйПр Егате\м/огк 
СоадеТэпкег 


& Зриа!Егатем/огк 


Соае1от [ег 
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Что обновляем 


Я РНР 8+ (возможно, на более ранних версиях тоже можно, 
но в нашем случае уже начали переход на 81, поэтому 
дождались завершения перехода) 


Ч Рзг/ Кеачез/Кезропзе. 
ЧУ Брался геаицез{ из рПр.://прие. 
Ч Файлы грузились из $_ЕТЕЕЗ 


Ч Использовался зе\сооК!е() для установки сессии, 
пришлось переписывать на: 


$гезроп5е- >и1{ПАдае4Неааег ( '5е{-Соок1е', $уа1ие); 
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Чистка состояния 


Ч Убираем любые операции в _аез{гис\() 

Ч Чистим статику 

/1ример: 

рготесфе Типсётоп с1еаг-фа{фе(): уота 
5е$5топ5: : < 1еаг[п{фапсе$ (); 


Оатабазе: : < 1еагСоппесетоп$ (); 
Ргоанс $ 5епаМе$ зазеъегутсе: : зеп д А1 1 То0иеие(); 
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Отладка 


каг Читр($уа1ие); 
ргтпЕ г($уа1ие); 
ате; 

есНо $уа|ие; 
ехтт; 

99(); 
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Локальное окружение 


Ч Переписываем БоскегШе с рпр-№рт и пашх 
Ч Переходим на хаебиз 

Ч Настраиваем гг.уат\ 

Ч Устанавливаем с РаскКаз!${ зависимости: 


“"зрга/Игоаагиппег": "у2.11/", 
"зрка/гоаагиппег-с!": "уг 1.0", 
"зрга/гоаагиппег-В р": "у2.0.4", 
"зрга/гоаагиппегм/огкег": "уг 1.5" 
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Что это дает? 


Если необходимо запустить Ц Не нагружаем ВК 
через пёшх. запросами на статику 

или политикой сСоГ$. 
Тосафтоп / { 


ГОХ а$5 ПЕЁр: / /рйр: 8083; 
Ре о Ч Минимизируем 


риски при первом 
переходе 
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115%еп: %ср://127.0.0.1:6003 


5егуег. 


соттапа: 


епу: 
- ХОЕВИб_5Е$$ЗТОМ: 1 
- РНР_ТОЕ_СОМЕТЕб: 
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уегзюп — это версия конфигурации. Не 
самого КК! 


грс — используется для подключения к 
КК из РНР-воркеров. Например, если не 
указать, то и лог КК собирать не сможет 


зегуег. 
соттапа — адрес, по которому будут 
доступны ваши РНР 
епу: переменные окружения, 
содержащие конфиги для ХаеБиз 


РР Кизза 
2022 


Бер: 

ПЕЕр: ааагезз — адрес, по которому будет 
доступно ваше РНР-приложение 

роо1.аеБив: {гче — означает, что будет 
роот.Чебуд: тгуе запущен с перезагрузкой под каждый 
запрос. В режиме разработки является 
оптимальной настройкой, так как вам не 
надо будет перезапускать сервер для 
деуе\ортепт обновления кода 
роо!1.аеБив: Га!зе + роо|.пит_м/огкегз: 2 


означает, что будет запущен один 
+1 (е_1о9дег_орТ1оп$: воркер 


аЧ9ге$5 : 


Теуе\: магп 


® 109_оутрит: 


|103 — блок отвечает за вывод логов и 
уровень логирования 
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ПЕфр.роот: 
пиут_могкег$: 4 
тах_7)06$: 09 
аосате_11теоут: 605$ 


де$тгоу_11тесут: 605$ 


дебуд: Та\$е 

5ирегу1$ог: 
мафси_11ск: 15$ 
ЕтТ: 180$ 
тах_могкКег_тетогу: 
ехес_Етт: 0$ 
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Беер.роо!: 
пигп_м/огкегз: п — количество запускаемых воркеров. 
Зависит от ваших доступных логических ядер 
тах_/оБз: О — максимальное количество итераций в 
одном воркере. О — без ограничений 
а!оса{е_{итеоц* — время в мс на запуск воркера 
аез гоу {итеочц* — время в мс на уничтожение 
воркера 
роо|.зирегмлзог 
м/атсп_аиск — проверка, что воркер жив 
{{ — максимальное время жизни воркера 
пах_м/огкег_тетогу — максимальная 
потребляемая память воркером в мегабайтах 
ехес {1 |: О — максимальное время, данное воркеру 
на выполнение запроса. О — без ограничений 
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петг1с$: 
тетисз — адрес сбора метрик в 


адге$$: 
Рготе\беиз 
5татиз: збахиз — Пеа&Пспеск для мониторинга 
системы 


® а9ЧЧге$5: 


18 577 РН Виза 


Коннекты к базе данных 


эпя|етоп-коннект к БД, 
который хранит его в 
статике. 


Если нас устраивает 
установка соединения на 
каждый запрос, то не 
забываем чистить статику. 
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Мем/ ОВ соппесе 


Еп!5И гедие${ 
Со$е ОВ соппесе 


Пример прохода одного запроса 
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Хранение коннектов к базе данных 


Ч эпяе{оп-коннект к БД оставляем 


геаче${ 
м/огкег 


рир 


У НЕ чистим статику 


Ч Реализуем переподключение к БД в 
случаях потери соединения 


У Не забываем: сколько воркеров, 


столько соединений. БД-параметр 
пах_соппесЧопз = м/огкегз гг + сгоп]обз + ацеце Пз‹епегз * п 


Перестаем тратить время Пример прохода одного запроса 


на установку соединения 
20 7 РНР Визза 


ши РН Кизза 


А какие проблемы? 


АЕЕОВЕ ВЕРОНТ 9/15/2022 
15:54:31 - 16:18:24 (23т 525) ы ь 
1 01 6 35.33% 

1ез{ сазез > Ч, 
После выкладки на тест 


АН ОКЕ КВЕРОКТ 10/4/2022 
17:48:58 - 18:18:55 (29т 56$) 


99.21% 
2 недели 1 01 1 


{е${ сазез 


К релизу 
22 
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Локальный прогон тестов 


гоаагиппег мА ‘гоаагиппег мо ц* 


в - р геоаа геоаа 
Список модераций 1.04$/486 тз 1.29 $/ /О0О2 тз 565 т$ / $20 тз 
Главная страница 469 тз / 590 тз 445 тз / 584 тз 65 тэ/ 44 тз 
Список аккаунтов 4.99 $ /1.05$ $ 1./6$/ 956 тз 5б/ тз / 552 тз 


Товар пота 955 тз / 445 тз 961 тз / /24 тз 155 тз / 142 тз 


По результатам анализа эффективности гоадгиппег (в таблице приведены первый 


запрос / повторный запрос) 
23 Ро РНР Визза 


Прогон на тестовом стенде 


ВоааВиппег 


Кезропзе Тите$ (п1$) Кезроп$е Тите$ (п1$) 
30,000 30,000 


25,000 


25000 Первые 

20000 задержки 
ответа: 

1оооо | | и Г5и ->180ч 


5,000 


20,000 
15,000 
10,000 


5,000 


11:18:44 11:19:54 11:21:04 11:22:14 1:23:24 11:24:35 11]25:45 11:26:55 11:28:05 11:29:15 


Узег$ 
МитьБег о? Ц$ег$ 


21:40:52 


Митьег о? Ц5ег$ 


Существенные 
замедления 
ответа: 
12Оиц -> $2О0и 


400 


0 Е ы 
:25: :28: 1:31: :34:5 ТЕ 21:43: 21:46: 21:49:53 


11:18:44 11:19:54 11:21:04 11:22:14 11:23:24 11:24:35 11:р5:45 11:26:55 11:28:05 11:29:15 
2022 


Системные проблемы 


СРИ — без изменений 
Сеть — без изменений 
Задействованная 


оперативная память — 
выросла (график) 


2, РНР Виза 
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Положительные стороны перехода Почему переход не всегда оправдан 


У Удалось достигнуть О Переписали много кода ядра 
пропускной способности в (базовый ЧЁ на 1О0ООО:+ строк) 
5 раза выше У Пол года на переход 

У Уменьшилось время ответа в У Есть проблемы приложения в 
2-8 раз работе с памятью 

У Появилась возможность Ч Усложнилась разработка и 
реализовать гибридное отладка 


РНР-Со-приложение 
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Если есть желание попробовать 


У Пример локального окружения 
У Две точки входа (ар!, ру с) 


У Простейшее АРТ 


У Отображение через Туи 
Б(р5.://=(ПчЬ.сот/ММогопта/гг-р|ауэгоцпа 


27 


7 РНР Низза 
2022 


7, 7 
й Р Отзывы по докладу _ 


внимание! 
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